|   | L # | Hits | Search Text                                                                         | DBs                                 |
|---|-----|------|-------------------------------------------------------------------------------------|-------------------------------------|
| 1 | L2  | 869  | (access\$3 writ\$3 updat\$3) near10 ((branch near5 (table history predict\$3)) bht) | USPAT;<br>US-PGPUB                  |
| 2 | L4  | 207  | (access\$3 writ\$3 updat\$3) near10 ((branch near5 (table history predict\$3)) bht) | EPO;<br>JPO;<br>DERWENT;<br>IBM TDB |
| 3 | L7  | 220  | 2 near10 (control controlled controlling simultaneous\$3 clock cycle)               | USPAT;<br>US-PGPUB                  |
| 4 | L6  | 29   | 4 near10 (control controlled controlling simultaneous\$3 clock cycle)               | EPO;<br>JPO;<br>DERWENT;<br>IBM_TDB |

12/05/2002, EAST Version: 1.03.0002



FIG. 4D



FIG. 4E

|    | Docum<br>ent<br>ID          | σ | Title                                                                                                                                                                                                                       | Current<br>OR                           |
|----|-----------------------------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
| 1  | JP<br>20011<br>00995<br>A   |   | DEVICE AND METHOD FOR WRITE CONTROL OVER BRANCH HISTORY INFORMATION                                                                                                                                                         | *************************************** |
| 2  | JP<br>11110<br>224 A        | ⊠ | LANGUAGE PROCESSING DEVICE, ITS METHOD AND INFORMATION STORAGE MEDIUM                                                                                                                                                       |                                         |
| 3  | JP<br>10171<br>652 A        | Ø | METHOD AND DEVICE FOR UPDATING OF BRANCH HISTORY TABLE                                                                                                                                                                      |                                         |
| 4  | JP<br>09083<br>552 A        | ⋈ | MULTIPROTOCOL CONTROL METHOD                                                                                                                                                                                                |                                         |
| 5  | JP<br>06236<br>270 A        | ☒ | METHOD AND DEVICE FOR IMPROVING BRANCH HISTORY PREDICTING PRECISION IN SUPERSCALAR PROCESSOR SYSTEM                                                                                                                         |                                         |
| 6  | JP<br>04242<br>431 A        | ☒ | INFORMATION PROCESSOR                                                                                                                                                                                                       |                                         |
| 7  | JP<br>02031<br>237 A        | ☒ | GENERATING SYSTEM FOR OPTIMUM BRANCH INSTRUCTION                                                                                                                                                                            |                                         |
| 8  | JP<br>01216<br>427 A        | ☒ | DATA PROCESSOR                                                                                                                                                                                                              |                                         |
| 9  | JP<br>63189<br>943 A        | ☒ | BRANCH FORECASTING CONTROL SYSTEM                                                                                                                                                                                           |                                         |
| 10 | JP<br>63005<br>442 A        | ☒ | PROGRAM LOOP DETECTING AND STORING DEVICE                                                                                                                                                                                   |                                         |
| 11 | JP<br>62262<br>143 A        | ☒ | GRAPHICAL LANGUAGE TRANSLATING DEVICE                                                                                                                                                                                       |                                         |
| 12 | JP<br>62130<br>460 A        | ☒ | DOCUMENT GENERATION SYSTEM INSTRUCTED BY BRANCH OFFICE                                                                                                                                                                      |                                         |
| 13 | JP<br>60175<br>148 A        | ☒ | INSTRUCTION PREFETCHING DEVICE                                                                                                                                                                                              |                                         |
| 14 | JP<br>60164<br>842 A        | ☒ | INSTRUCTION PREFETCHING DEVICE                                                                                                                                                                                              |                                         |
| 15 | JP<br>57147<br>197 A        | ☒ | MEMORY PROTECTION SYSTEM                                                                                                                                                                                                    |                                         |
| 16 | EP<br>60587<br>6 A1         | ☒ | Method and system for enhanced branch history prediction accuracy in a superscalar processor system.                                                                                                                        |                                         |
| 17 | NA900<br>1369               | ☒ | Branch Resolution in the Cache                                                                                                                                                                                              |                                         |
| 18 | NN831<br>02283              | Ø | Functional AC Card Test Using a DC Tester                                                                                                                                                                                   |                                         |
| 19 | US<br>63473<br>69 B         | Ø | Microprocessor operating method involves reading counter values from branch history table in response to accessing branch history table using generated primary and secondary branch history table indexes                  |                                         |
| 20 | US<br>20010<br>02026<br>7 A | ⊠ | Pipeline processing apparatus controls supply of updated latest branch prediction status to succeeding conditional branch instruction by comparing the branch instruction at preceding pipeline stage with succeeding stage |                                         |
| 21 | US<br>59789<br>07 A         | ☒ | Updating method of storage arrays in superscalar microprocessor                                                                                                                                                             |                                         |
| 22 | US<br>58782<br>55 A         | ☒ | Delayed update unit for branch prediction array for superscalar microprocessor                                                                                                                                              |                                         |

Speculative Branching

below in FIGS. 5 through 7. in software. The speculative branching feature is illustrated instruction stream or may require a jump to a different point the possible instructions streams may serially follow the first 15 the correct path. It should be understood that either one of issued along the incorrect path and issue instructions along will then attempt to reverse the affects of the instructions determines that it "guessed" incorrectly. The data processor issuing instructions along the selected path, however, if it 10 instruction stream is correct. The data processor will stop new instruction stream if it later determines that the new instruction stream. The data processor will continue along its whether the selected instruction stream is in fact the correct tion streams before the data processor actually determines one that branches to one of two (or more) possible instrucprocessor that implements a speculative branching scheme is data processor that supports speculative branching. A data Rename buffer 14 may be modified to operate within a

element, etc. bit of B memory element equals the MRA bit of B memory equals the MRA bit of A memory element, the Shadow MRA bit. Specifically, the Shadow MRA bit of A memory element MRA bit in the Shadow MRA bit associated with each MRA with FIGS. 3 and 4. Rename buffer 14 saves a copy of each issuing the four instructions described above in connection in FIG. 2 if data processor 10 takes a speculative branch after FIG. 5 depicts the contents of rename buffer 14 illustrated

architectural register #5. The Shadow MRA bits are not element E will contain the most recently allocated version of element B to a zero logic state to reflect that memory As a result, rename buffer 14 sets the MRA bit of memory memory element E and will write to architectural register #5. the new instruction stream. This next instruction is allocated in FIG. 2 after data processor 10 issues one instruction from FIG. 6 depicts the contents of rename buffer 14 illustrated

the incorrect instruction stream. data processor 10 will also invalidate all instructions along MRA bits. Rename buffer 14 or, perhaps, a branch unit of buffer 14 will copy the Shadow bits back into the associated however, data processor 10 guessed incorrectly, then rename MRA bits, overwriting the vector illustrated in FIG. 6. II, buffer 14 will again copy the MRA bits into the Shadow takes a second speculative branch. At that point, rename 14 will ignore its Shadow MRA bits until data processor 10 continue along the same instruction stream. Rename buffer when it branched speculatively, then data processor 10 will If data processor 10 "guessed" the correct instruction path

number of incorrectly issued instructions. 60 procedure, however, will produce the same results given any only one MRA bit needed to be restored. The disclosed fore, only one memory element needed to be invalidated and determined the correct instruction stream to follow. Theretration only one instruction issued before data processor 10 55 Shadow bits back into the MRA bits. In the present illusdates memory element E and copies the contents of the an incorrect instruction stream. Rename buffer 14 invaliin FIG. 2 after data processor 10 determines that it followed FIG. 7 depicts the contents of rename buffer 14 illustrated

case, a second Shadow MRA bit may be provided for each determines if the first speculative branch was correct. In this plete. In that case, rename buffer 14 will forward the 65 to be able to take a second speculative branch before it ing. For instance, it may be desirable for data processor 10 increased to support multiple levels of speculative branch-The number of Shadow bits per memory element may be

> forwarded to it by execution unit 12. ignores the forwarded operand but latches the rename tag an invalid data signal (data not present), execution unit 12 buffer 14 therefore contains a zero logic state. In the case of bit associated with the selected memory element of rename the entry is assumed to be "not present." The Data Present circuit 18 via operand bus/RB 28. In this scenario, however, Tag, a high Valid bit and a high MRA bit to forwarding Tag field matching the requested Architectural Register File wards the Data field having an Architectural Register File unit 18 vis operand bus 20. Again, rename buffer 14 forand present on operand bus/RB 28 to forward to execution warding circuit 18. Forwarding circuit 18 selects the oper-Tag. Rename buffer 14 therefore indicates a "hit" to for-

operand and rename tag. operand at the same time rename buffer 14 latches the rename tag on result/request tag bus 26 and can latch the Execution unit 12 will be able to identify this operand by the via result bus 24 and result/request tag bus 26, respectively. will forward the operand and rename tag to rename buffer 14 operand's associated rename tag. The second execution unit eventually return a result that is the desired operand with the process is called "snooping." A second execution unit will monitor result bus 24 and result/request tag bus 26. This During a subsequent clock cycle, execution unit 12 will

discussion. indicate that the value of the field is not relevant to the with binary numbers. Blank entries in FIGS. 3 through 7 elements and eight architectural registers would be identified through 7 to avoid confusion. In practice, the seven memory eight Data fields for eight architectural registers, labeled 0 elements, labeled A through G, that store eight results in illustrated examples, rename buffer 14 has seven memory 14 illustrated in FIG. 2 at various sequential times. In the FIGS. 3 through 7 depict the contents of the rename buffer

Normal Operation

architectural register, here architectural registers #4, #5 and that each is or will be the most recent version of some Present bits. The MRA bit of all the memory elements reflect cated by the zero logic state of the two corresponding Data tively. These latter instructions have not completed as indithat will write to architectural registers #5 and #7, respecments B and C will contain the results of two instructions architectural register #4. The Data fields of memory ele-Present bit set to a one logic state) that will write to element A already contains the result of an instruction (Data allocated to three instructions. The Data field of memory in FIG. 2 after memory elements A, B and C have been FIG. 3 depicts the contents of rename buffer 14 illustrated

instruction associated with memory element D is not comelement D. At the depicted moment, the result of the element D depending upon the Data Present bit of memory receive the Data field or the Rename Tag field of memory that requests the contents of architectural register #4 will is set to a zero logic state. As a result, any later instruction A one logic state and the MRA bit of memory element A instruction issue, the MRA bit of memory element D is set like the instruction associated with memory element A. At additional instruction will write to architectural register #4 element D, has been allocated to some instruction. This in FIG. 2 after an additional memory element, memory HG. 4 depicts the contents of rename buffer 14 illustrated

by the zero logic state of each memory element's Valid bit. #7. Memory elements D through G are not valid as indicated

tural register #4. Rename Tag field to any execution unit requesting architec-

|    | Docum<br>ent<br>ID   | ם | Title                                                                                                                                                                                                                                                     | Current<br>OR                           |
|----|----------------------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
| 23 | US<br>58753<br>24 A  | × | Delayed updating mechanism for branch prediction array in superscalar microprocessor                                                                                                                                                                      |                                         |
| 24 | JP<br>09244<br>892 A | ⊠ | CPU for computer - includes effective request flag in read-out buffer which indicates effect of error in branch prediction on read-out data field                                                                                                         |                                         |
| 25 | AU<br>95232<br>31 A  | Ø | Memory control system for private branch exchange - has memory table in CPU with read circuit accessing information file in secondary memory for storage in table for access unit control                                                                 | *************************************** |
| 26 | EP<br>66761<br>8 A   | ☒ | Access control method for particular address on disc - providing branch data for one control method in table used by different control method                                                                                                             |                                         |
| 27 | EP<br>65133<br>1 A   |   | Write buffer for super-pipelined super-scalar microprocessor - directs each write to memory to write buffer rather than memory bus or cache memory and writes contents of write buffer to cache or main memory when memory bus or cache becomes available |                                         |
| 28 | EP<br>60587<br>6 A   |   | Branch history prediction for processor - using branch history table with predictive field for each fetch cycle in multiple instruction access accessed by partial instruction address for updating                                                       |                                         |
| 29 | EP<br>25845<br>3 B   |   | Instruction prefetch control appts. for data processor - has branch history table storing paired branch instruction address and branch destination address of branch instruction                                                                          |                                         |

chart \$4\$ illustrates how rename buffer \$14\$ may incorporate the speculative branching feature described above in connection with FIGS. 5 through 7. Rename buffer \$14\$ may nection with FIGS. 5 through 7. Rename buffer \$14\$ may execute the steps depicted in FIG. \$10\$ at the beginning of each data processor clock cycle. Rename buffer \$14\$ determines if data processor \$10\$ takes a speculative branch, step 56. If data processor \$10\$ has taken a speculative branch, then rename buffer \$14\$ does not take a speculative branch, then \$60\$. If data processor \$10\$ does not take a speculative branch, then then rename buffer \$14\$ flows directly to step \$60\$. If data processor \$10\$ does not take a speculative branch, then then rename buffer \$14\$ flows directly to step \$60\$. If data processor \$10\$ flollowed an incorrect instruction stream, step \$60\$. If data processor \$10\$ followed an incorrect instruction stream, step \$60\$. If data processor \$10\$ followed an incorrect instruction stream, step \$60\$. If data processor \$10\$ did followed an incorrect instruction stream, step \$60\$. If data processor \$10\$ did followed an incorrect instruction stream, step \$60\$. If data processor \$10\$ did followed an incorrect instruction stream, step \$60\$. If data processor \$10\$ did followed an incorrect instruction stream, step \$60\$. If data processor \$10\$ did followed an instruction stream, step \$60\$. If data processor \$10\$ did followed an instruction stream, step \$60\$. If data processor \$10\$ did followed an instruction stream, step \$60\$. If data processor \$10\$ did followed an instruction stream, and \$10\$ did followed an instruction stream, and \$10\$ did followed an instruction stream, and \$10\$ did followed an instruction stream.

Rename buffer 14 then determines if a data processor indicates that data processor 10 followed an incorrect instruction stream, step 60. If data processor 10 did follow an incorrect instruction stream, then rename buffer 14 invalidates each Valid bit associated with an instruction, step 62. Rename buffer 14 also copies each Shadow MRA bit back to the corresponding MRA bit, step 64. Rename buffer 14 then the follows to the end of flow chart 54. If data processor 10 then flows to the end of flow chart 54. If data processor 10 then flows to the end of flow chart 54. If data processor 10 then flows to the end of flow chart 54 from step buffer 14 flows directly to the end of flow chart 54 from step 60.

Although the present invention has been described with reference to a specific embodiment, further modifications and improvements will occur to those skilled in the art. For instance, many of the functions attributed above to a particular portion of data processor 10 may be performed by a different portion of a particular data processor. The name of the unit performing a necessary function or the division of labor among a group of units, therefore, its not part of the invention. It is to be understood therefore, that the invention encompasses all such modifications that do not depart from the spirit and scope of the invention as defined in the appended claims.

What is claimed is:

I. A data processor comprising:

a plurality of execution units, the execution units operable to perform a plurality of instructions received from a memory system, at least one of the plurality of instructions requiring an operand, at least one of the plurality of instructions generating a result;

a plurality of architectural registers coupled to at least one of the execution units, the plurality of architectural registers supplying operands to the at least one of the plurality of execution units, the plurality of architectural registers periodically receiving the result of the at least one instruction generating a result;

a plurality of memory means, each memory means storing a result, a tag representative of the architectural register associated with the result and a first-most-recently-allocated bit and a second-most-recently-allocated bit each associated with the result;

allocation means coupled to at least one of the execution units and to the plurality of memory means, the allocation means periodically receiving a first tag identifying an architectural register, storing the first tag in a predetermined one of the memory means, setting the first-most-recently-allocated bit associated with the subset of the memory elements to a second logic state, setting each first-most-recently-allocated bit of a subset of the memory elements to a second logic state, the subset of the memory elements comprising a tag logic state, setting each first-most-recently-allocated bit in an associated second-most-recently-allocated bit in a second-most-recently-allocated bit in a second bit in a second-most-recently-allocated bit in a second-most-recently-allocated bit in a second bit in a

memory element. Upon execution of the second outstanding speculative branch, the contents of the MRA bits would be stored in the second Shadow MRA bits. Rename buffer 14 will then restore the Mth Shadow MRA bits to the MRA bits outstanding speculative branch unit determines that the Mth outstanding speculative branch is incorrect (where M is an integer index). In general, one Shadow MRA bit may be integer index). In general, one Shadow MRA bit may be desired for each level of speculative branching that is desired.

FIG. 8 depicts a flow chart 36 of one set of steps operable to implement the disclosed invention. Rename buffer 14 performs flow chart 36 each time an operand is requested by some execution unit. Rename buffer 14 compares the Architectural Register File Tag of the requested operand to each Architectural Register File Tag field in rename buffer 14 for as match, step 38. Rename buffer 14 then branches to a path 40 or to a path 42 depending upon whether rename buffer 14 for 15 finds a match or does not find a match, respectively. Step 38 is more fully described below in connection with FIG. 9.

Continuing along path 40, rename buffer 14 will transmit 20

Continuing along path 40, rename buffer 14 will transmit as "hit" signal to forwarding circuit 18 indicating that forwarding circuit 18 should forward the operand supplied by rename buffer 14 to operand bus 20, step 44. Rename buffer 14 will then forward the matching rename tag field and Data field (if any) and the Data Present bit to execution unit 18, 25 step 46. As described above, execution unit 18 will disregard ecrtain of these fields depending upon the value of the Data certain of these fields depending upon the value of the Data Present field.

Continuing along path 42, rename buffer 14 will transmit a "miss" signal to forwarding circuit 18 should forward the operand supplied forwarding circuit 18 should forward the operand supplied by architectural register file 16, step 48. Rename buffer 14 may or may not forward any other data to execution unit 12 depending upon the implementation details of rename buffer 14. Regardless, according to the protocol described above, any data forwarded to execution unit 12 will be ignored any data forwarded to execution unit 12 will be ignored given the valid data signal supplied by architectural register file 16.

Both paths within flow chart 36 then merge at the end of 40 flow chart 36.

sable memory ("CAM") cells. If the rename buffer 14 is a 60 rename buffer 14 may be a small block of content addrescounter is incremented if no match is found. Conversely, counter, the memory cell contents are compared, and the which a memory cell is addressed according to an indexed ("RAM") cells, then step 50 may involve an iterative loop in 55 designed as a small block of Random Access Memory rename buffer 14. For instance, if rename buffer 14 is hardware implementation of the memory elements in The details of compare step 50 will depend upon the depending upon whether or not it found a match in step 50. 50 buffer 14 then branches, in step 52, to path 40 or 42 and the MRA bit of each memory element 35. Rename (2) the Architectural Register File Tag field, the Valid bit, requested operand, a one logic level, and a one logic level to rename buffer compares, respectively, (1) the tag of the 45 performs a tag compare, step 50. As described above, implement step 38 illustrated in FIG. 8. Rename buffer 14 FIG. 9 depicts a flow chart of one set of steps operable to

FIG. 10 depicts a flow chart 54 of one set of steps operable to implement the disclosed invention. In particular, flow

cally output its Rename Tag field, DATA field, and Data

other. The CAM cell having the desired fields will automati-

be compared to the input operand tag in parallel with each

block of CAM cells, then the contents of each CAM cell may

59

|    | Docum<br>ent<br>ID           | ט   | Title                                                                                            | Current<br>OR  |
|----|------------------------------|-----|--------------------------------------------------------------------------------------------------|----------------|
| 1  | US<br>20020<br>17432<br>8 A1 |     | Method for cancelling speculative conditional delay slot instructions                            | 712/235        |
| 2  | US<br>20020<br>17432<br>2 A1 | ⊠   | Method for cancelling conditional delay slot instructions                                        | 712/218        |
| 3  | US<br>20020<br>08779<br>4 A1 | 101 | Apparatus and method for speculative prefetching after data cache misses                         | 711/126        |
| 4  | US<br>20020<br>08331<br>0 A1 | ⋈   | METHOD AND APPARATUS FOR PREDICTING LOOP EXIT BRANCHES                                           | 712/233        |
| 5  | US<br>20020<br>08067<br>7 A1 | ⊠   | Semiconductor memory device                                                                      | 365/233        |
| 6  | US<br>20020<br>07833<br>2 A1 |     | Conflict free parallel read access to a bank interleaved branch predictor in a processor         | 712/240        |
| 7  | US<br>20020<br>06937<br>5 A1 |     | System, method, and article of manufacture for data transfer across clock domains                | 713/400        |
| 8  | US<br>20010<br>02751<br>5 A1 | ☒   | Apparatus and method of controlling instruction fetch                                            | 712/207        |
| 9  | US<br>20010<br>02197<br>4 A1 | ☒   | Branch predictor suitable for multi-processing microprocessor                                    | 712/240        |
| 10 | US<br>20010<br>02026<br>7 A1 |     | Pipeline processing apparatus with improved efficiency of branch prediction, and method therefor | 712/239        |
| 11 | US<br>20010<br>02026<br>5 A1 | ⊠   | Data processor with multi-command instruction words                                              | 712/24         |
| 12 | US<br>20010<br>01690<br>3 A1 | ☒   | Software branch prediction filtering for a microprocessor                                        | 712/239        |
| 13 | US<br>20010<br>01134<br>6 A1 |     | Branch prediction method, arithmetic and logic unit, and information processing apparatus        | 712/239        |
| 14 | US<br>20010<br>00753<br>3 A1 |     | Non-volatile semiconductor memory device and semiconductor<br>disk device                        | 365/185<br>.11 |
| 15 | US<br>64670<br>64 B1         | Ø   | Viterbi decoder                                                                                  | 714/795        |
| 16 | US<br>64532<br>78 B1         |     | Flexible implementation of a system management mode (SMM) in a processor                         | 703/27         |
| 17 | US<br>64456<br>15 B2         |     | Non-volatile semiconductor memory device and semiconductor disk device                           | 365/185<br>.11 |
| 18 | US<br>64426<br>79 B1         | ☒   | Apparatus and method for guard outcome prediction                                                | 712/218        |

शिक्षांट शबाद: set logically equivalent to the requested tag and the first met-most-recently-allocated-bit-field of the selected set, the contents of the tag field and the contents of the of sets, forwarding a result associated with a selected allocated bit field, respectively, of each of the plurality state to the tag field and to the first-most-recentlyresult, comparing the requested tag and the first logic at a third time, receiving a requested tag of a requested plurality of sets logically equivalent to the second tag: each of the contents of the tag fields of the subset of the allocated bit field of a subset of the plurality of sets, storing a second logic state in the first-most-recentlyrecently-allocated bit assuming the first logic state, and executed by the execution unit, the second first-mostsecond result being an output of a second instruction allocated bit associated with the second result, the with a second result and the second first-most-recentlytag identifying an address of a memory cell associated bit in a second one of the plurality of sets, the second second tag and a second first-most-recently-allocated at a second time subsequent to the first time, storing a

processor and storing the first result in the first memory first result from a communication bus within the data at a fourth time subsequent to the first time, receiving the

allocated bit field. cated bit field in an associated second-most-recentlystoring the contents of each first-most-recently-allospeculative branch instruction to the execution unit and at a fifth time subsequent to the first time, issuing a

> the selected result associated with a selected one of the an execution unit responsive to the step of comparing, of memory means, and forwarding a selected result to comparing the first tag to each tag stored in the plurality 5 request comprising the first tag, the forwarding means warding means receiving a request for an operand, the units and to the plurality of memory means, the forforwarding means coupled to at least one of the execution

the first logic state of the first-most-recently-allocated state to the first one of the architectural registers and to first-most-recently-allocated bit corresponding in logic plurality of memory means comprising a tag and a 10 plurality of memory means, the selected one of the

associated with the selected result. address of the one of the plurality of memory means tag means coupled to the forwarding means to forward an 15

2. A method of operating a data processor comprising the

siebs oi:

bit, respectively; and

logic state: first first-most-recently-allocated bit assuming a first recently-allocated bit associated with the first result, the execution unit of the data processor, the first first-mostbeing an output of a first instruction executed by an memory cell associated with a first result, the first result field, the first tag identifying an address of a first bit-field, and a second-most-recently-allocated-bitcomprising a tag field, a first-most-recently-allocatedof a plurality of sets, each one of the plurality of sets recently-allocated-bit-field, respectively, of a first one recently-allocated bit in a tag field and in a first-mostat a first time, storing a first tag and a first first-most-

|    | Docum<br>ent<br>ID   | σ | Title                                                                                                                                                | Current<br>OR |
|----|----------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 19 | US<br>64386<br>82 B1 | Ø | Method and apparatus for predicting loop exit branches                                                                                               | 712/241       |
| 20 | US<br>64386<br>64 B1 | Ø | Microcode patch device and method for patching microcode using match registers and patch routines                                                    | 711/154       |
| 21 | US<br>64271<br>92 B1 | Ø | Method and apparatus for caching victimized branch predictions                                                                                       | 711/133       |
| 22 | US<br>64250<br>75 B1 | Ø | Branch prediction device with two levels of branch prediction cache                                                                                  | 712/239       |
| 23 | US<br>63973<br>26 B1 | Ø | Method and circuit for preloading prediction circuits in microprocessors                                                                             | 712/240       |
| 24 | US<br>63935<br>49 B1 | ⊠ | Instruction alignment unit for routing variable byte-length instructions                                                                             | 712/204       |
| 25 | US<br>63743<br>51 B1 | ☒ | Software branch prediction filtering for a microprocessor                                                                                            | 712/239       |
| 26 | US<br>63599<br>09 B1 | ⊠ | Switch device for relayin G cells or packets on demand                                                                                               | 370/522       |
| 27 | US<br>63538<br>82 B1 | ☒ | Reducing branch prediction interference of opposite well behaved branches sharing history entry by static prediction correctness based updating      | 712/239       |
| 28 | US<br>63517<br>97 B1 | ☒ | Translation look-aside buffer for storing region configuration bits and method of operation                                                          | 711/20        |
| 29 | US<br>63517<br>89 B1 | × | Built-in self-test circuit and method for validating an associative data array                                                                       | 711/12        |
| 30 | US<br>63473<br>69 B1 | × | Method and circuit for single cycle multiple branch history table access                                                                             | 712/240       |
| 31 | US<br>63413<br>48 B1 | Ø | Software branch prediction filtering for a microprocessor                                                                                            | 712/23        |
| 32 | US<br>63361<br>78 B1 | Ø | RISC86 instruction set                                                                                                                               | 712/23        |
| 33 | US<br>63321<br>91 B1 | ☒ | System for canceling speculatively fetched instructions following a branch mis-prediction in a microprocessor                                        | 712/240       |
| 34 | US<br>63306<br>62 B1 | × | Apparatus including a fetch unit to include branch history information to increase performance of multi-cylce pipelined branch prediction structures | 712/236       |
| 35 | US<br>63144<br>93 B1 | Ø | Branch history cache                                                                                                                                 | 711/13        |
| 36 | US<br>63016<br>47 B1 | Ø | Real mode translation look-aside buffer and method of operation                                                                                      | 711/20        |
| 37 | US<br>62826<br>29 B1 | Ø | Pipelined processor for performing parallel instruction recording and register assigning                                                             | 712/23        |
| 38 | US<br>62791<br>07 B1 | ⊠ | Branch selectors associated with byte ranges within an instruction cache for rapidly identifying branch predictions                                  | 712/239       |
| 39 | US<br>62726<br>24 B1 | ☒ | Method and apparatus for predicting multiple conditional branches                                                                                    | 712/239       |
| 40 | US<br>62694<br>36 B1 | ☒ | Superscalar microprocessor configured to predict return addresses from a return stack storage                                                        | 712/23        |
| 41 | US<br>62667<br>52 B1 | ☒ | Reverse TLB for providing branch target address in a microprocessor having a physically-tagged cache                                                 | 711/200       |



# United States Patent [19]

### Tran et al.

[11] Patent Number: 5,881,278

[45] Date of Patent:

Mar. 9, 1999

[54] RETURN ADDRESS PREDICTION SYSTEM WHICH ADJUSTS THE CONTENTS OF RETURN STACK STORAGE TO ENABLE CONTINUED PREDICTION AFTER A MISPREDICTED BRANCH

[75] Inventors: Thang M. Tran; Rupaka
Mahalingaiah, both of Austin, Tex.

[73] Assignce: Advanced Micro Devices, Inc., Sunnyvale, Calif.

[21] Appl. No.: 550,296

[22] Filed: Oct. 30, 1995

#### [56] References Cited

#### U.S. PATENT DOCUMENTS

4,044,338 8/1977 Wolf . 4,453,212 6/1984 Gaither et al. .

(List continued on next page.)

#### FOREIGN PATENT DOCUMENTS

| 0259095 | 3/1988  | European Pat. Off |
|---------|---------|-------------------|
| 0381471 | 8/1990  | European Pat. Off |
| 0459232 | 12/1991 | European Pat. Off |
| 0649084 | 4/1995  | European Pat. Off |
| 2263985 | 8/1993  | United Kingdom .  |
| 2263987 | 8/1993  | United Kingdom.   |
| 2281422 | 3/1995  | United Kingdom.   |
| 2287111 | 9/1995  | United Kingdom .  |
|         |         |                   |

#### OTHER PUBLICATIONS

Intel, "Chapter 2: Microprocessor Architecture Overview," pp. 2-1 through 2-4.

Michael Slater, "AMD's K5 Designed to Outrun Pentium," Microprocessor Report, vol. 8, No. 14, Oct. 24, 1994, 7 pages.

Sebastian Rupley and John Clyman, "P6: The Next Step?," PC Magazine, Sep. 12, 1995, 16 pages.

Tom R. Halfhill, "AMD K6 Takes on Intel P6,"BYTE, Jan. 1996, 4 pages.

Dialog, Microprocessor Report, Oct. 24, 1994, pp. 1–7. Foreign Search Report dated Feb. 26, 1997 for PCT/US96/11842.

Tomasula, R. M., "An Efficient Algorithm for Exploiting Multiple Arithmetic Units," IBM Journal, Jan. 1967, pp. 25-33.

Dialog, Microprocessor Report, Oct. 24, 1994, pp. 1–7. IBM Technical Disclosure Bulletin, "Subroutine Call/Return Stack," Apr. 30, 1988, vol. 30, No. 11, pp. 221–225.

IBM Technical Disclosure Bulletin, "Highly Accurate Subroutine Stack Prediction Mechanism," Mar. 10, 1986, vol. 28, No. 10, pp. 4635–4637.

Yeh and Patt, "Branch History Table Indexing to Prevent Pipeline Bubbles in Wide-Issue Superscalar Processors," Dept. of Electrical Engineering, University of Michigan, An Arbor, 1993, pp. 164-175.

Primary Examiner—Thomas C. Lee Assistant Examiner—Gautam R. Patel Attorney, Agent, or Firm—Conley, Rose & Tayon; B. Noel Kivlin; Lawrence J. Merkel

#### [57] ABSTRACT

A return prediction unit is provided which is configured to predict return addresses for return instructions according to a return stack storage included therein. The return stack storage is a stack structure configured to store return addresses associated with previously detected call instructions. Return addresses may be predicted for return instructions early in the instruction processing pipeline of the microprocessor. In one embodiment, the return stack storage additionally stores a call tag and a return tag with each return address. The call tag and return tag respectively identify call and return instructions associated with the return address. These tags may be compared to a branch tag conveyed to the return prediction unit upon detection of a branch misprediction. The results of the comparisons may be used to adjust the contents of the return stack storage with respect to the misprediction. The return prediction unit may continue to predict return addresses correctly following a mispredicted branch instruction.

#### 39 Claims, 45 Drawing Sheets



|    | Docum<br>ent<br>ID   | σ           | Title                                                                                                                                                                                                                         | Current |
|----|----------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 42 | US<br>62533<br>16 B1 | ☒           | Three state branch history using one bit in a branch prediction mechanism                                                                                                                                                     | 712/239 |
| 43 | US<br>62471<br>23 B1 | ☒           | Branch prediction mechanism employing branch selectors to select a branch prediction                                                                                                                                          | 712/239 |
| 44 | US<br>62471<br>22 B1 | $\boxtimes$ | Method and apparatus for performing branch prediction combining static and dynamic branch predictors                                                                                                                          | 712/239 |
| 45 | US<br>62232<br>80 B1 | ☒           | Method and circuit for preloading prediction circuits in microprocessors                                                                                                                                                      | 712/240 |
| 46 | US<br>62021<br>42 B1 | ☒           | Microcode scan unit for scanning microcode instructions using predecode data                                                                                                                                                  | 712/204 |
| 47 | US<br>61924<br>68 B1 | ×           | Apparatus and method for detecting microbranches early                                                                                                                                                                        | 712/231 |
| 48 | US<br>61890<br>91 B1 | M           | Apparatus and method for speculatively updating global history and restoring same on branch misprediction detection                                                                                                           | 712/240 |
| 49 | US<br>61890<br>68 B1 | Ø           | Superscalar microprocessor employing a data cache capable of performing store accesses in a single clock cycle                                                                                                                | 711/3   |
| 50 | US<br>61856<br>74 B1 | ☒           | Method and apparatus for reconstructing the address of the next instruction to be completed in a pipelined processor                                                                                                          | 712/230 |
| 51 | US<br>61784<br>98 B1 | ☒           | Storing predicted branch target address in different storage according to importance hint in branch prediction instruction                                                                                                    | 712/239 |
| 52 | US<br>61675<br>10 A  | ⊠           | Instruction cache configured to provide instructions to a microprocessor having a clock cycle time less than a cache access time of said instruction cache                                                                    | 712/239 |
| 53 | US<br>61516<br>72 A  | $\boxtimes$ | Methods and apparatus for reducing interference in a branch history table of a microprocessor                                                                                                                                 | 712/239 |
| 54 | US<br>61417<br>48 A  | ×           | Branch selectors associated with byte ranges within an instruction cache for rapidly identifying branch predictions                                                                                                           | 712/239 |
| 55 | US<br>61417<br>40 A  | 1001        | Apparatus and method for microcode patching for generating a next address                                                                                                                                                     | 711/215 |
| 56 | US<br>61254<br>44 A  | ⊠           | Millimode capable computer system providing global branch history table disables and separate millicode disables which enable millicode disable to be turned off for some sections of code execution but not disabled for all | 712/245 |
| 57 | US<br>61192<br>22 A  | $\boxtimes$ | Combined branch prediction and cache prefetch in a microprocessor                                                                                                                                                             | 712/238 |
| 58 | US<br>61192<br>20 A  | ☒           | Method of and apparatus for supplying multiple instruction strings whose addresses are discontinued by branch instructions                                                                                                    | 712/235 |
| 59 | US<br>61087<br>76 A  | $\boxtimes$ | Globally or selectively disabling branch history table operations during sensitive portion of millicode routine in millimode supporting computer                                                                              | 712/240 |
| 60 | US<br>61087<br>74 A  | ⊠           | Branch prediction with added selector bits to increase branch prediction capacity and flexibility with minimal added bits                                                                                                     | 712/240 |
| 61 | US<br>61065<br>73 A  | ☒           | Apparatus and method for tracing microprocessor instructions                                                                                                                                                                  | 717/128 |
| 62 | US<br>61015<br>95 A  |             | Fetching instructions from an instruction cache using sequential way prediction                                                                                                                                               | 712/205 |
| 63 | US<br>61015<br>77 A  | ☒           | Pipelined instruction cache and branch prediction mechanism therefor                                                                                                                                                          | 711/125 |

# 5,881,278 Page 2

|           | U.S. PA | TENT DOCUMENTS    |                  | 5,339,422 | 8/1994  | Brender et al 395/700 |  |
|-----------|---------|-------------------|------------------|-----------|---------|-----------------------|--|
|           |         |                   |                  | 5,355,459 | 10/1994 | Matsuo et al 395/589  |  |
| 4,504,927 | 3/1985  | Callan            | 364/900          |           |         | Narita et al          |  |
| 4,807,115 | 2/1989  | Tomg.             |                  |           |         | Matsuo et al          |  |
| 4,858,105 | 8/1989  | Kuriyama et al    |                  |           |         | Steely, Jr. et al     |  |
| - •       |         | Johnson .         |                  |           |         | Hoyt et al 395/376    |  |
| * *       | •       | Steely, Jr. et al | 395/586          |           |         | Hoyt et al            |  |
| •         |         | Mehta             | -                |           |         | Hoyt et al            |  |
|           |         | McFarland et al   | 070,010          |           |         | McGarity 395/414      |  |
| * *       | ·       | Favor et al       |                  |           |         | Van Dyke et al        |  |
|           | •       | Stahi             | 305 <i>[</i> 700 |           |         | <b>-</b>              |  |
|           |         | Eickemeyer        | •                |           |         | White et al           |  |
| J,JIJ,UJ4 | 3/1724  | ETCRCHICACI       | <i>373/1</i> 00  | 3,033,U98 | 0/177/  | Witt et al 395/386    |  |

|    | Docum<br>ent<br>ID  | ប           | Title                                                                                                                                                                               | Current<br>OR |
|----|---------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 64 | US<br>60932<br>13 A | ×           | Flexible implementation of a system management mode (SMM) in a processor                                                                                                            | 703/27        |
| 65 | US<br>60818<br>87 A | ⊠           | System for passing an index value with each prediction in forward direction to enable truth predictor to associate truth value with particular branch instruction                   | 712/239       |
| 66 | US<br>60790<br>06 A | $\boxtimes$ | Stride-based data address prediction structure                                                                                                                                      | 711/213       |
| 67 | US<br>60790<br>05 A | $\boxtimes$ | Microprocessor including virtual address branch prediction and current page register to provide page portion of virtual and physical fetch address                                  | 711/213       |
| 68 | US<br>60790<br>03 A | Ø           | Reverse TLB for providing branch target address in a microprocessor having a physically-tagged cache                                                                                | 711/200       |
| 69 | US<br>60732<br>30 A | $\boxtimes$ | Instruction fetch unit configured to provide sequential way prediction for sequential instruction fetches                                                                           | 712/205       |
| 70 | US<br>60651<br>15 A | ⊠           | Processor and method for speculatively executing instructions from multiple instruction streams indicated by a branch instruction                                                   | 712/235       |
| 71 | US<br>60650<br>91 A | $\sim$      | Translation look-aside buffer slice circuit and method of operation                                                                                                                 | 711/3         |
| 72 | US<br>60556<br>30 A | ×           | System and method for processing a plurality of branch instructions by a plurality of storage devices and pipeline units                                                            | 712/240       |
| 73 | US<br>60527<br>73 A | Ø           | DPGA-coupled microprocessors                                                                                                                                                        | 712/43        |
| 74 | US<br>60444<br>78 A | $\boxtimes$ | Cache with finely granular locked-down regions                                                                                                                                      | 714/42        |
| 75 | US<br>60322<br>52 A | ×           | Apparatus and method for efficient loop control in a superscalar microprocessor                                                                                                     | 712/233       |
| 76 | US<br>60322<br>41 A | ⊠           | Fast RAM for use in an address translation circuit and method of operation                                                                                                          | 711/207       |
| 77 | US<br>60165<br>45 A | $\boxtimes$ | Reduced size storage apparatus for storing cache-line-related data in a high frequency microprocessor                                                                               | 712/238       |
| 78 | US<br>60147<br>41 A | ☒           | Apparatus and method for predicting an end of a microcode<br>loop                                                                                                                   | 712/233       |
| 79 | US<br>60147<br>34 A | ⊠           | Superscalar microprocessor configured to predict return addresses from a return stack storage                                                                                       | 712/23        |
| 80 | US<br>60095<br>13 A | ☒           | Apparatus and method for detecting microbranches early                                                                                                                              | 712/231       |
| 81 | US<br>60063<br>24 A | $\boxtimes$ | High performance superscalar alignment unit                                                                                                                                         | 712/204       |
| 82 | US<br>60031<br>28 A | 10.71       | Number of pipeline stages and loop length related counter differential based end-loop prediction                                                                                    | 712/241       |
| 83 | US<br>59960<br>71 A | ⊠           | Detecting self-modifying code in a pipelined processor with branch processing by comparing latched store address to subsequent target address                                       | 712/238       |
| 84 | US<br>59957<br>49 A | ☒           | Branch prediction mechanism employing branch selectors to select a branch prediction                                                                                                | 712/239       |
| 85 | US<br>59875<br>61 A |             | Superscalar microprocessor employing a data cache capable of performing store accesses in a single clock cycle                                                                      | 711/3         |
| 86 | US<br>59833<br>37 A | ×           | Apparatus and method for patching an instruction by providing a substitute instruction or instructions from an external memory responsive to detecting an opcode of the instruction | 712/32        |



|     | Docum<br>ent<br>ID  | σ | Title                                                                                                                                              | Current |
|-----|---------------------|---|----------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 37  | US<br>59789<br>08 A | ⊠ | Computer instruction supply                                                                                                                        | 712/240 |
| 38  | US<br>59789<br>07 A | ⊠ | Delayed update register for an array                                                                                                               | 712/239 |
| 39  | US<br>59789<br>06 A | Ø | Branch selectors associated with byte ranges within an instruction cache for rapidly identifying branch predictions                                | 712/23  |
| 90  | US<br>59745<br>43 A | ⊠ | Apparatus and method for performing subroutine call and return operations                                                                          | 712/24  |
| 91  | US<br>59705<br>09 A | Ø | Hit determination circuit for selecting a data set based on miss determinations in other data sets and method of operation                         | 711/12  |
| 92  | US<br>59681<br>69 A | ⊠ | Superscalar microprocessor stack structure for judging validity of predicted subroutine return addresses                                           | 712/23  |
| 93  | US<br>59681<br>63 A | ⊠ | Microcode scan unit for scanning microcode instructions using predecode data                                                                       | 712/20  |
| 94  | US<br>59616<br>38 A | Ø | Branch prediction mechanism employing branch selectors to select a branch prediction                                                               | 712/23  |
| 95  | US<br>59548<br>16 A | ⊠ | Branch selector prediction                                                                                                                         | 712/23  |
| 96  | US<br>59499<br>95 A | Ø | Programmable branch prediction system and method for inserting prediction operation which is independent of execution of program code              | 712/23  |
| 97  | US<br>59467<br>18 A | ⊠ |                                                                                                                                                    | 711/20  |
| 98  | US<br>59467<br>05 A | × | Avoidance of cache synonyms                                                                                                                        | 711/10  |
| 99  | US<br>59408<br>58 A | ⊠ | Cache circuit with programmable sizing and method of operation                                                                                     | 711/13  |
| 100 | US<br>59387<br>61 A | ⊠ | Method and apparatus for branch target prediction                                                                                                  | 712/23  |
| 101 | US<br>59352<br>39 A | × | Parallel mask decoder and method for generating said mask                                                                                          | 712/22  |
| 102 | US<br>59336<br>29 A | × | Apparatus and method for detecting microbranches early                                                                                             | 712/24  |
| 103 | ບຣ                  | × | Apparatus and method for tracing microprocessor instructions                                                                                       | 712/22  |
| 104 | US                  | × | Speculative register storage for storing speculative results corresponding to register updated by a plurality of concurrently recorded instruction | 712/21  |
| 105 | US                  | ⊠ | Information processing apparatus which accurately predicts                                                                                         | 712/23  |
| 106 | บร                  | ⊠ |                                                                                                                                                    | 712/1   |
| 107 | บร                  | ⊠ | Limited run branch prediction                                                                                                                      | 712/23  |
| 108 | บร                  | ⊠ | Instruction decoder including two-way emulation code branching                                                                                     | 712/23  |
| 109 | US                  | × | Apparatus and method for native mode processing in a RISC-based CISC processor                                                                     | 712/20  |



FIG. 2

|     | Docum<br>ent<br>ID  | ប   | Title                                                                                                                                                                   | Current<br>OR |
|-----|---------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 110 | US<br>59078<br>60 A | ⊠   | System and method of retiring store data from a write buffer                                                                                                            | 711/117       |
| 111 | US<br>59013<br>07 A | Ø   | Processor having a selectively configurable branch prediction unit that can access a branch prediction utilizing bits derived from a plurality of sources               | 712/240       |
| 112 | US<br>58988<br>65 A | ☒   | Apparatus and method for predicting an end of loop for string instructions                                                                                              | 712/239       |
| 113 | US<br>58982<br>86 A | ☒   | Digital servo control system for a data recording disk file with improved saturation modelling                                                                          | 318/569       |
| 114 | US<br>58929<br>36 A | ☒   | Speculative register file for storing speculative register states and removing dependencies between instructions utilizing the register                                 | 712/216       |
| 115 | US<br>58871<br>52 A | ×   | Load/store unit with multiple oldest outstanding instruction pointers for completing store and load/store miss instructions                                             | 712/217       |
| 116 | US<br>58812<br>78 A | ⊠   | Return address prediction system which adjusts the contents of return stack storage to enable continued prediction after a mispredicted branch                          | 712/242       |
| 117 | US<br>58782<br>55 A | 101 | Update unit for providing a delayed update to a branch prediction array                                                                                                 | 712/240       |
| 118 | US<br>58753<br>25 A | ☒   | Processor having reduced branch history table size through global branch history compression and method of branch prediction utilizing compressed global branch history | 712/240       |
| 119 | US<br>58753<br>24 A | ⊠   | Superscalar microprocessor which delays update of branch prediction information in response to branch misprediction until a subsequent idle clock                       | 712/238       |
| 120 | US<br>58753<br>15 A | ⊠   | Parallel and scalable instruction scanning unit                                                                                                                         | 712/204       |
| 121 | US<br>58731<br>15 A | ⊠   | Cache memory                                                                                                                                                            | 711/129       |
| 122 | US<br>58729<br>89 A |     | Processor having a register configuration suited for parallel execution control of loop processing:                                                                     | 712/23        |
| 123 | US<br>58677<br>24 A | ☒   | Integrated routing and shifting circuit and method of operation                                                                                                         | 712/22        |
| 124 | US<br>58676<br>98 A | ☒   | Apparatus and method for accessing a branch target buffer                                                                                                               | 712/238       |
| 125 | US<br>58647<br>07 A | ☒   | Superscalar microprocessor configured to predict return addresses from a return stack storage                                                                           | 712/23        |
| 126 | US<br>58646<br>97 A | 101 | Microprocessor using combined actual and speculative branch history prediction                                                                                          | 712/240       |
| 127 | US<br>58601<br>04 A | ☒   | Data cache which speculatively updates a predicted data cache storage location with store data and subsequently corrects mispredicted updates                           | 711/137       |
| 128 | US<br>58600<br>17 A | Ø   | Processor and method for speculatively executing instructions from multiple instruction streams indicated by a branch instruction                                       | 712/23        |
| 129 | US<br>58599<br>91 A | Ø   | Parallel and scalable method for identifying valid instructions and a superscalar microprocessor including an instruction scanning unit employing the method            | 712/204       |
| 130 | US<br>58549<br>21 A | ☒   | Stride-based data address prediction structure                                                                                                                          | 712/239       |
| 131 | US<br>58549<br>13 A | ☒   | Microprocessor with an architecture mode control capable of supporting extensions of two distinct instruction-set architectures                                         | 712/210       |
| 132 | US<br>58527<br>27 A |     | Instruction scanning unit for locating instructions via parallel scanning of start and end byte information                                                             | 712/215       |

| Return PC | Call Tag | Ret. Tag             | S       | R<br>V | CRV | IXC | IStart |
|-----------|----------|----------------------|---------|--------|-----|-----|--------|
|           | -        |                      |         |        |     |     |        |
| • •       |          | Return Stack Storage | ck Stor | age    |     |     |        |
| •         | •        |                      |         |        |     |     |        |

|     | Docum<br>ent<br>ID                                                                                                                       | ט                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Title                                                                                                          | Current<br>OR |  |  |  |  |  |
|-----|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|---------------|--|--|--|--|--|
| 133 | US<br>58505<br>32 A                                                                                                                      | Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Invalid instruction scan unit for detecting invalid predecode data corresponding to instructions being fetched | 712/213       |  |  |  |  |  |
| 134 | US<br>58484<br>33 A                                                                                                                      | ⊠                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ay prediction unit and a method for operating the same                                                         |               |  |  |  |  |  |
| 135 | US<br>58482<br>69 A                                                                                                                      | predicting mechanism for enhancing accuracy in branch prediction by reference to data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                |               |  |  |  |  |  |
| 136 | US 58389 Method and apparatus for rotating active instructions in a parallel data processor                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                |               |  |  |  |  |  |
| 137 | US 58357   Hardware instruction scheduler for short execution unit latencies                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                |               |  |  |  |  |  |
| 138 | US Superscalar microprocessor load/store unit employing a 58322 Sunified buffer and separate pointers for load and store 97 A operations |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                |               |  |  |  |  |  |
| 139 | US<br>58322<br>49 A                                                                                                                      | ⊠                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | High performance superscalar alignment unit                                                                    | 712/204       |  |  |  |  |  |
| 140 | US<br>58288<br>74 A                                                                                                                      | ☒                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Past-history filtered branch prediction                                                                        | 712/240       |  |  |  |  |  |
| 141 | US<br>58260<br>71 A                                                                                                                      | ☒                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Parallel mask decoder and method for generating said mask                                                      | 712/224       |  |  |  |  |  |
| 142 | US<br>58225<br>75 A                                                                                                                      | US Branch prediction storage for storing branch prediction 58225 🛛 information such that a corresponding tag may be routed with                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                |               |  |  |  |  |  |
| 143 | US 58225 74 A Functional unit with a pointer for mispredicted resolution, and a superscalar microprocessor employing the same            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                |               |  |  |  |  |  |
| 144 | US<br>58225<br>59 A                                                                                                                      | US Apparatus and method for aligning variable byte-length    Second Column   S |                                                                                                                |               |  |  |  |  |  |
| 145 | US<br>58225<br>58 A                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Method and apparatus for predecoding variable byte-length instructions within a superscalar microprocessor     | 712/213       |  |  |  |  |  |
| 146 | US<br>58190<br>59 A                                                                                                                      | ⊠                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Predecode unit adapted for variable byte-length instruction set processors and method of operating the same    | 712/213       |  |  |  |  |  |
| 147 | US<br>58190<br>57 A                                                                                                                      | Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Superscalar microprocessor including an instruction alignment unit with limited dispatch to decode units       | 712/204       |  |  |  |  |  |
| 148 | US<br>58157<br>00 A                                                                                                                      | ⊠                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Branch prediction table having pointers identifying other branches within common instruction cache lines       | 712/240       |  |  |  |  |  |
| 149 | US<br>58128<br>38 A                                                                                                                      | ☒                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Branch history table                                                                                           | 712/239       |  |  |  |  |  |
| 150 | US<br>58092<br>71 A                                                                                                                      | ☒                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Method and apparatus for changing flow of control in a processor                                               | 712/208       |  |  |  |  |  |
| 151 | US<br>57940<br>63 A                                                                                                                      | US Instruction decoder including emulation using indirect  57940 Specifiers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                |               |  |  |  |  |  |
| 152 | US 57940 Shared branch prediction structure 28 A                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                | 712/240       |  |  |  |  |  |
| 153 | US<br>57939<br>40 A                                                                                                                      | ☒                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Data processing apparatus                                                                                      | 714/1         |  |  |  |  |  |
| 154 | US<br>57817<br>89 A                                                                                                                      | ⊠                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Superscaler microprocessor employing a parallel mask decoder                                                   | 712/23        |  |  |  |  |  |
| 155 | US<br>57747<br>10 A                                                                                                                      | ⊠                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Cache line branch prediction scheme that shares among sets of a set associative cache                          | 712/238       |  |  |  |  |  |



FIG. 3

|     | Docum<br>ent<br>ID                                                                                                                                                                                       | σ                                                           | Title                                                                                                                                                                 | Current<br>OR |  |  |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--|--|
| 156 | US<br>57686<br>10 A                                                                                                                                                                                      | $\boxtimes$                                                 | Lookahead register value generator and a superscalar microprocessor employing same                                                                                    | 712/23        |  |  |
| 157 | Superscalar microprocessor employing a way prediction unit to predict the way of an instruction fetch address and to concurrently provide a branch prediction address corresponding to the fetch address |                                                             |                                                                                                                                                                       |               |  |  |
| 158 | US<br>57581<br>43 A                                                                                                                                                                                      | ⊠                                                           | Method for updating a branch history table in a processor which resolves multiple branches in a single cycle                                                          | 712/240       |  |  |
| 159 | US<br>57581<br>12 A                                                                                                                                                                                      | ⊠                                                           | Pipeline processor with enhanced method and apparatus for restoring register-renaming information in the event of a branch misprediction                              | 712/217       |  |  |
| 160 | US Instruction cache configured to provide instructions to a 57522 Microprocessor having a clock cycle time less than a cache 59 A access time of said instruction cache                                 |                                                             |                                                                                                                                                                       |               |  |  |
| 161 | US 57520 Superscalar microprocessor employing away prediction structure                                                                                                                                  |                                                             |                                                                                                                                                                       |               |  |  |
| 162 | US<br>57489<br>76 A                                                                                                                                                                                      | ☒                                                           | Mechanism for maintaining data coherency in a branch history instruction cache                                                                                        | 712/240       |  |  |
| 163 | US<br>57404<br>18 A                                                                                                                                                                                      | ☒                                                           | Pipelined processor carrying out branch prediction by BTB                                                                                                             | 712/239       |  |  |
| 164 | US<br>57404<br>15 A                                                                                                                                                                                      | Ø                                                           | Instruction supplying apparatus with a branch target buffer having the contents so updated as to enhance branch prediction accuracy                                   | 712/238       |  |  |
| 165 | US<br>57375<br>90 A                                                                                                                                                                                      | Branch prediction system using limited branch target buffer |                                                                                                                                                                       |               |  |  |
| 166 | US<br>57348<br>81 A                                                                                                                                                                                      | ☒                                                           | Detecting short branches in a prefetch buffer using target location information in a branch target cache                                                              | 712/238       |  |  |
| 167 | US<br>57297<br>28 A                                                                                                                                                                                      | ☒                                                           | Method and apparatus for predicting, clearing and redirecting unpredicted changes in instruction flow in a microprocessor                                             | 712/234       |  |  |
| 168 | US<br>57218<br>55 A                                                                                                                                                                                      | ⊠                                                           | Method for pipeline processing of instructions by controlling access to a reorder buffer using a register file outside the reorder buffer                             | 712/218       |  |  |
| 169 | US<br>57154<br>40 A                                                                                                                                                                                      | ☒                                                           | Branch instruction executing device for tracing branch instruments based on instruction type                                                                          | 712/233       |  |  |
| 170 | US<br>57040<br>54 A                                                                                                                                                                                      | ☒                                                           | Counterflow pipeline processor architecture for semi-custom application specific IC's                                                                                 | 712/212       |  |  |
| 171 | US<br>57014<br>48 A                                                                                                                                                                                      | ☒                                                           | Detecting segment limit violations for branch target when the branch unit does not supply the linear address                                                          | 712/233       |  |  |
| 172 | US<br>56969<br>19 A                                                                                                                                                                                      | ☒                                                           | Accessing a desk-type recording medium having reproduction control data                                                                                               | 345/841       |  |  |
| 173 | US<br>56873<br>38 A                                                                                                                                                                                      | ☒                                                           | Method and apparatus for maintaining a macro instruction for refetching in a pipelined processor                                                                      | 712/205       |  |  |
| 174 | US<br>56871<br>10 A                                                                                                                                                                                      | ☒                                                           | Array having an update circuit for updating a storage<br>location with a value stored in another storage location                                                     | 365/154       |  |  |
| 175 | US<br>56447<br>45 A                                                                                                                                                                                      | ☒                                                           | Apparatus for replacing data availability information for an instruction subsequent to a branch with previous availability information upon branch prediction failure | 712/216       |  |  |
| 176 | US<br>56425<br>00 A                                                                                                                                                                                      | Ø                                                           | Method and apparatus for controlling instruction in pipeline processor                                                                                                | 712/233       |  |  |
| 177 | US<br>56341<br>19 A                                                                                                                                                                                      | ☒                                                           | Computer processing unit employing a separate millicode branch history table                                                                                          | 712/240       |  |  |



FIG. 4A

|     | Docum<br>ent<br>ID                                                                      | Ū                                                          | Title                                                                                                                                                                       | Current<br>OR |  |  |  |  |
|-----|-----------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--|--|--|--|
| 178 | US<br>56320<br>28 A                                                                     | ⊠                                                          | Hardware support for fast software emulation of unimplemented instructions                                                                                                  | 703/26        |  |  |  |  |
| 179 | US<br>56196<br>62 A                                                                     |                                                            | Memory reference tagging                                                                                                                                                    | 712/216       |  |  |  |  |
| 180 | US<br>55840<br>09 A                                                                     |                                                            | System and method of retiring store data from a write buffer                                                                                                                | 711/117       |  |  |  |  |
| 181 | US<br>55840<br>01 A                                                                     |                                                            | Branch target buffer for dynamically predicting branch instruction outcomes using a predicted branch history                                                                |               |  |  |  |  |
| 182 | US<br>55817<br>19 A                                                                     | $\boxtimes$                                                | Multiple block line prediction                                                                                                                                              |               |  |  |  |  |
| 183 | US<br>55772<br>17 A                                                                     | ⊠                                                          | Method and apparatus for a branch target buffer with shared branch pattern tables for associated branch predictions                                                         | 712/200       |  |  |  |  |
| 184 | US<br>55641 Past-history filtered branch prediction<br>18 A                             |                                                            |                                                                                                                                                                             |               |  |  |  |  |
| 185 | US Data processor with programmable levels of speculative                               |                                                            |                                                                                                                                                                             |               |  |  |  |  |
| 186 | US 55220 Branch target and next instruction address calculation in a pipeline processor |                                                            |                                                                                                                                                                             |               |  |  |  |  |
| 187 | US<br>55198<br>41 A                                                                     | Multi instruction register mapper                          |                                                                                                                                                                             |               |  |  |  |  |
| 188 | US<br>55176<br>14 A                                                                     | S  5176 🛛 Data compression/encryption processing apparatus |                                                                                                                                                                             |               |  |  |  |  |
| 189 | US<br>55111<br>75 A                                                                     | $\boxtimes$                                                | Method an apparatus for store-into-instruction-stream detection and maintaining branch prediction cache consistency                                                         | 712/216       |  |  |  |  |
| 190 | US<br>55048<br>70 A                                                                     | 10/1                                                       | Branch prediction device enabling simultaneous access to a content-addressed memory for retrieval and registration                                                          | 712/238       |  |  |  |  |
| 191 | US<br>54715<br>97 A                                                                     | ⊠                                                          | System and method for executing branch instructions wherein branch target addresses are dynamically selectable under programmer control from writable branch address tables | 711/215       |  |  |  |  |
| 192 | US<br>54540<br>89 A                                                                     | 101                                                        | Branch look ahead adder for use in an instruction pipeline sequencer with multiple instruction decoding                                                                     | 711/213       |  |  |  |  |
| 193 | US<br>54248<br>82 A                                                                     | $\boxtimes$                                                | Signal processor for discriminating recording data                                                                                                                          | 360/46        |  |  |  |  |
| 194 | US<br>53945<br>30 A                                                                     |                                                            | Arrangement for predicting a branch target address in the second iteration of a short loop                                                                                  | 712/240       |  |  |  |  |
| 195 | US<br>53677<br>03 A                                                                     | 171                                                        | Method and system for enhanced branch history prediction accuracy in a superscalar processor system                                                                         | 712/23        |  |  |  |  |
| 196 | US<br>53275<br>36 A                                                                     | ⊠                                                          | Microprocessor having branch prediction function                                                                                                                            | 712/238       |  |  |  |  |
| 197 | US<br>53136<br>34 A                                                                     | $\boxtimes$                                                | Computer system branch prediction of subroutine returns                                                                                                                     | 712/240       |  |  |  |  |
| 198 | US<br>52281<br>31 A                                                                     |                                                            | Data processor with selectively enabled and disabled branch prediction operation                                                                                            | 712/240       |  |  |  |  |
| 199 | US<br>52261<br>30 A                                                                     |                                                            | Method and apparatus for store-into-instruction-stream detection and maintaining branch prediction cache consistency                                                        | 712/238       |  |  |  |  |
| 200 | US<br>51931<br>56 A                                                                     | ⊠                                                          | Data processor with pipeline which disables exception processing for non-taken branches                                                                                     | 712/239       |  |  |  |  |



FIG. 4B



FIG. 4C

|   | L # | Hits | Search Text                                                                          | DBs                                 |
|---|-----|------|--------------------------------------------------------------------------------------|-------------------------------------|
| 1 | L2  | 869  | (access\$3 writ\$3 updat\$3) near10 ((branch near5 (table history predict\$3)) bht)  | USPAT;<br>US-PGPUB                  |
| 2 | L4  | 207  | (access\$3 writ\$3 updat\$3) near10 ((branch near5 (table history predict\$3)) bht)  | EPO;<br>JPO;<br>DERWENT;<br>IBM_TDB |
| 3 | L7  | 220  | <pre>2 near10 (control controlled controlling simultaneous\$3 clock cycle)</pre>     | USPAT;<br>US-PGPUB                  |
| 4 | L6  | 29   | 4 near10 (control controlled controlling simultaneous\$3 clock cycle)                | EPO;<br>JPO;<br>DERWENT;<br>IBM_TDB |
| 5 | L8  | 1245 | (access\$3 writ\$3 updat\$3) near20 ((branch near20 (table history predict\$3)) bht) | USPAT;<br>US-PGPUB                  |
| 6 | L10 | 258  | (access\$3 writ\$3 updat\$3) near20 ((branch near20 (table history predict\$3)) bht) | EPO;<br>JPO;<br>DERWENT;<br>IBM_TDB |
| 7 | L12 | 11   | 10 near30 (control controlled controlling simultaneous\$3 clock cycle) not 6         | DERWENT;<br>IBM_TDB                 |
| 8 | L9  | 73   | 8 near30 (control controlled controlling simultaneous\$3 clock cycle) not 7          | USPAT;<br>US-PGPUB                  |



FIG. 14

|    | Docum<br>ent<br>ID          | σ           | Title                                                                                                                                                                                  | Current<br>OR                          |
|----|-----------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| 1  | JP<br>08286<br>913 A        | 1 1         | METHOD AND DEVICE FOR GENERATING ADDRESS OF INSTRUCTION TO BE FINISHED NEXT IN PIPELINE PROCESSOR                                                                                      | ************************************** |
| 2  | JP<br>04148<br>359 A        | ⊠           | HIGH SPEED FRONT END PROCESSOR                                                                                                                                                         |                                        |
| 3  | JP<br>01284<br>927 A        | ☒           | INFORMATION PROCESSOR                                                                                                                                                                  |                                        |
| 4  | JP<br>63208<br>941 A        | ☒           | MANAGING SYSTEM FOR UPDATING HISTORY OF PROGRAM PATH                                                                                                                                   |                                        |
| 5  | JP<br>61257<br>041 A        | $\boxtimes$ | PACKET EXCHANGE SYSTEM OF HIERARCHY EXCHANGE SYSTEM                                                                                                                                    |                                        |
| 6  | JP<br>55041<br>515 A        | ☒           | HOME COMPUTER                                                                                                                                                                          |                                        |
| 7  | EP<br>73683<br>0 Al         | IVI         | Method and apparatus for reconstructing the address of the next instruction to be completed in a pipelined processor                                                                   |                                        |
| 8  | NN920<br>1330               | $\boxtimes$ | Using History to Improve the Handling of Address Generation<br>Interlocks in Branch Instructions.                                                                                      |                                        |
| 9  | US<br>20020<br>07833<br>2 A | 13/1        | Computer system includes bank control logic to ensure that no<br>two look-ups access same bank in same clock cycle                                                                     |                                        |
| 10 | GB<br>23213<br>23 A         |             | Branch prediction method for computer program - involves<br>accessing branch target buffer using pointer of instruction<br>whose interval from fetch of branch instruction is smallest |                                        |
| 11 | EP<br>21074<br>2 A          | ☒           | Processing information through multi-program system - using with computer program sequence, command shell with set of programs and program control files                               |                                        |



FIG. 5

|    | Docum<br>ent<br>ID                                                                                                                                 | σ                                                                  | Title                                                                                                                                                                  | Current<br>OR |  |  |  |
|----|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--|--|--|
| 1  | US 20020 13992 7 A1 Method of and system for detecting and correcting mode switching in diffractive-based laser scanning systems                   |                                                                    |                                                                                                                                                                        | 250/235       |  |  |  |
| 2  | US<br>20020<br>11213<br>1 A1                                                                                                                       | 13 Specifying access control and caching on operands               |                                                                                                                                                                        |               |  |  |  |
| 3  | US<br>20020<br>06935<br>1 A1                                                                                                                       |                                                                    | Memory data access structure and method suitable for use in a processor                                                                                                |               |  |  |  |
| 4  | US 20020 06908 6 Al Web linked database for tracking clinical activities and competencies and evaluation of program resources and program outcomes |                                                                    |                                                                                                                                                                        |               |  |  |  |
| 5  | US 20020 04139 6 Al Storage medium control apparatus, image forming apparatus using the same, and control method therefor                          |                                                                    |                                                                                                                                                                        |               |  |  |  |
| б  | US 20020 03567 7 A1  METHOD AND APPARATUS FOR PRE-PROCESSING INSTRUCTIONS FOR A PROCESSOR                                                          |                                                                    |                                                                                                                                                                        |               |  |  |  |
| 7  | US 20010 03749 Apparatus and method for generating optimization objects 7 A1                                                                       |                                                                    |                                                                                                                                                                        |               |  |  |  |
| 8  | US<br>64424<br>79 B1                                                                                                                               | 1424 🛛 Method and apparatus for a location sensitive database      |                                                                                                                                                                        | 701/213       |  |  |  |
| 9  | US<br>64381<br>81 B1                                                                                                                               |                                                                    |                                                                                                                                                                        | 375/341       |  |  |  |
| 10 | US<br>64250<br>76 B1                                                                                                                               | ⊠                                                                  | Instruction prediction based on filtering                                                                                                                              | 712/239       |  |  |  |
| 11 | US<br>63603<br>18 B1                                                                                                                               | ⊠                                                                  | Configurable branch prediction for a processor performing speculative execution                                                                                        | 712/240       |  |  |  |
| 12 | US<br>63518<br>39 B1                                                                                                                               | 101                                                                | State metric memory of viterbi decoder and its decoding method                                                                                                         | 714/795       |  |  |  |
| 13 | US<br>63393<br>83 B1                                                                                                                               |                                                                    | Traffic signal control apparatus optimizing signal control parameter by rolling horizon scheme                                                                         | 340/907       |  |  |  |
| 14 | US<br>62928<br>79 B1                                                                                                                               |                                                                    | Method and apparatus to specify access control list and cache enabling and cache coherency requirement enabling on individual operands of an instruction of a computer | 711/214       |  |  |  |
| 15 | US<br>62826<br>39 B1                                                                                                                               | US 62826 Configurable branch prediction for a processor performing |                                                                                                                                                                        | 712/240       |  |  |  |
| 16 | US<br>62821<br>83 B1                                                                                                                               | ☒                                                                  | Method for authorizing couplings between devices in a capability addressable network                                                                                   | 370/338       |  |  |  |
| 17 | US<br>62302<br>60 B1                                                                                                                               | 2302 Circuit arrangement and method of speculative instruction     |                                                                                                                                                                        | 712/239       |  |  |  |
| 18 | US<br>61700<br>54 B1                                                                                                                               |                                                                    | Method and apparatus for predicting target addresses for return from subroutine instructions utilizing a return address cache                                          | 712/242       |  |  |  |
| 19 | US<br>61548<br>33 A                                                                                                                                | ⊠                                                                  | System for recovering from a concurrent branch target buffer read with a write allocation by invalidating and then reinstating the instruction pointer                 | 712/238       |  |  |  |
| 20 | US<br>61449<br>82 A                                                                                                                                | ☒                                                                  | Pipeline processor and computing system including an apparatus for tracking pipeline resources                                                                         | 709/104       |  |  |  |



FIG. 6

|               | <u>x86</u> | Register O | rganization |        |        |
|---------------|------------|------------|-------------|--------|--------|
| 31            | 16         | 15 8       | 7 0         | 16-bit | 32-bit |
|               |            | AH         | AL          | AX     | EAX    |
|               |            | DH         | DL          | DX     | DAX    |
|               |            | СН         | CL          | CX     | CAX    |
|               |            | ВН         | BL          | вх     | BAX    |
|               |            | В          | Р           |        | EBP    |
| <del></del> - |            |            | SI          |        | ESI    |
|               |            |            | )I          |        | EDI    |
| <del></del>   |            | S          | Р           |        | ESP    |

FIG. 7

|    | Docum<br>ent<br>ID                                                         | ט                                                                                                    | Title                                                                                                                                                                             | Current |  |  |  |
|----|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--|--|--|
| 21 | US<br>61087<br>77 A                                                        | ☒                                                                                                    | Configurable branch prediction for a processor performing speculative execution                                                                                                   | 712/240 |  |  |  |
| 22 | US<br>61087<br>75 A                                                        | ⊠                                                                                                    | namically loadable pattern history tables in a multi-task<br>croprocessor                                                                                                         |         |  |  |  |
| 23 | US<br>61087<br>69 A                                                        | ☒                                                                                                    | Dependency table for reducing dependency checking hardware                                                                                                                        |         |  |  |  |
| 24 | US<br>61015<br>86 A                                                        | ☒                                                                                                    | Memory access control circuit                                                                                                                                                     | 711/163 |  |  |  |
| 25 | US<br>60921<br>87 A                                                        | ☒                                                                                                    | Instruction prediction based on filtering                                                                                                                                         | 712/239 |  |  |  |
| 26 | US<br>60852<br>38 A                                                        | ☒                                                                                                    | Virtual LAN system                                                                                                                                                                | 709/223 |  |  |  |
| 27 | US 60524 🛛 Voice response service apparatus 41 A                           |                                                                                                      |                                                                                                                                                                                   |         |  |  |  |
| 28 | US<br>60444<br>59 A                                                        | ☒                                                                                                    | Branch prediction apparatus having branch target buffer for effectively processing branch instruction                                                                             | 712/237 |  |  |  |
| 29 | US<br>59408<br>57 A                                                        | ×                                                                                                    | Instruction cache memory apparatus with advanced read function that predicts whether to read out a next instruction block including an address register, a counter and a selector |         |  |  |  |
| 30 | US<br>59403<br>78 A                                                        | $\boxtimes$                                                                                          | Call control in exchange suitable for intelligent network                                                                                                                         | 370/259 |  |  |  |
| 31 | US 58600 Method for tracking pipeline resources in a superscalar processor |                                                                                                      |                                                                                                                                                                                   |         |  |  |  |
| 32 | US<br>58570<br>89 A                                                        | ⊠                                                                                                    | Floating point stack and exchange instruction                                                                                                                                     | 712/222 |  |  |  |
| 33 | US<br>58451<br>02 A                                                        |                                                                                                      | Determining microcode entry points and prefix bytes using a parallel logic technique                                                                                              | 712/211 |  |  |  |
| 34 | US<br>58394<br>83 A                                                        | $\boxtimes$                                                                                          | Beverage dispenser with serving time monitor                                                                                                                                      | 141/1   |  |  |  |
| 35 | US<br>58357<br>54 A                                                        | ⊠                                                                                                    | Branch prediction system for superscalar processor                                                                                                                                | 712/239 |  |  |  |
| 36 | US<br>58156<br>99 A                                                        | Ø                                                                                                    | Configurable branch prediction for a processor performing speculative execution                                                                                                   | 712/239 |  |  |  |
| 37 | US<br>58092<br>94 A                                                        | ☒                                                                                                    | Parallel processing unit which processes branch instructions without decreased performance when a branch is taken                                                                 | 712/233 |  |  |  |
| 38 | US<br>58058<br>78 A                                                        | ☒                                                                                                    | Method and apparatus for generating branch predictions for multiple branch instructions indexed by a single instruction pointer                                                   | 712/239 |  |  |  |
| 39 | US<br>57969<br>88 A                                                        | 171                                                                                                  | Method and system using dedicated location to share information between real mode and protected mode drivers                                                                      | 709/321 |  |  |  |
| 40 | US<br>57963<br>56 A                                                        | US Data compressing apparatus, data restoring apparatus and data  57963 Compressing/restoring system |                                                                                                                                                                                   | 341/51  |  |  |  |
| 41 | US<br>RE357<br>94 E                                                        | ☒                                                                                                    | System for reducing delay for execution subsequent to correctly predicted branch instruction using fetch information stored with each block of instructions in cache              | 712/239 |  |  |  |
| 42 | US<br>56969<br>55 A                                                        | ☒                                                                                                    | Floating point stack and exchange instruction                                                                                                                                     | 712/222 |  |  |  |
| 43 | US<br>56842<br>60 A                                                        | ☒                                                                                                    | Apparatus and method for generation and synthesis of audio                                                                                                                        | 84/604  |  |  |  |



FIG. 8



| _  | Docum<br>ent<br>ID                                                                                                                                             | υ                                                                                               | Title                                                                                                                                           | Current      |  |  |  |  |  |
|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--|--|--|--|--|
| 44 | US 56756 45 A  Method and apparatus for securing executable programs against copying                                                                           |                                                                                                 |                                                                                                                                                 |              |  |  |  |  |  |
| 45 | US<br>56550<br>96 A                                                                                                                                            | Ø                                                                                               | ethod and apparatus for dynamic scheduling of instructions of ensure sequentially coherent data in a processor employing out-of-order execution |              |  |  |  |  |  |
| 46 | US<br>56491<br>08 A                                                                                                                                            | Combined progressive and source routing control for connection-oriented communications networks |                                                                                                                                                 |              |  |  |  |  |  |
| 47 | US<br>56340<br>27 A                                                                                                                                            | 56340 Arranged cache tag memories                                                               |                                                                                                                                                 |              |  |  |  |  |  |
| 48 | US 56048 87 A  Method and system using dedicated location to share information between real and protected mode device drivers                                  |                                                                                                 |                                                                                                                                                 |              |  |  |  |  |  |
| 49 | US<br>55926<br>34 A                                                                                                                                            | $\boxtimes$                                                                                     | Zero-cycle multi-state branch cache prediction data processing system and method thereof                                                        | 712/23       |  |  |  |  |  |
| 50 | US 55686 Multiprocessor system with a shared control store accessed with predicted addresses                                                                   |                                                                                                 |                                                                                                                                                 |              |  |  |  |  |  |
| 51 | US 54813 Apparatus for adaptively generating a decoder table for variable-length codes using a stored coding table                                             |                                                                                                 |                                                                                                                                                 |              |  |  |  |  |  |
| 52 | US 54637 A Data processing system having prediction by using an embedded guess bit of remapped and compressed opcodes                                          |                                                                                                 |                                                                                                                                                 |              |  |  |  |  |  |
| 53 | US Instruction pipeline sequencer in which state information of 54598  an instruction travels through pipe stages until the instruction execution is completed |                                                                                                 |                                                                                                                                                 |              |  |  |  |  |  |
| 54 | US 54541 Configurable branch prediction for a processor performing speculative execution                                                                       |                                                                                                 |                                                                                                                                                 |              |  |  |  |  |  |
| 55 | US<br>54539<br>27 A                                                                                                                                            | Ø                                                                                               | Data processor for processing branch instructions                                                                                               | 712/23       |  |  |  |  |  |
| 56 | US<br>53882<br>39 A                                                                                                                                            | Ø                                                                                               | Operand address modification system                                                                                                             | 711/22       |  |  |  |  |  |
| 57 | US<br>53534<br>21 A                                                                                                                                            | ☒                                                                                               | Multi-prediction branch prediction mechanism                                                                                                    | 712/24       |  |  |  |  |  |
| 58 | US<br>53455<br>71 A                                                                                                                                            | ☒                                                                                               | System for controlling branch history table                                                                                                     | 712/24       |  |  |  |  |  |
| 59 | US<br>53177<br>00 A                                                                                                                                            | ×                                                                                               | Program history for pipelined processor including temporary storage queues for storing branch addresses                                         | 712/24       |  |  |  |  |  |
| 60 | US<br>53053<br>75 A                                                                                                                                            | ☒                                                                                               | Information service apparatus                                                                                                                   | 379/88<br>27 |  |  |  |  |  |
| 61 | US<br>53052<br>17 A                                                                                                                                            | ☒                                                                                               | Method and system for controlling automatic guided vehicle                                                                                      | 701/25       |  |  |  |  |  |
| 62 | US<br>53032<br>34 A                                                                                                                                            | ☒                                                                                               | Random access data communication system with slot assignment capability for contending users                                                    | 370/44       |  |  |  |  |  |
| 63 | US<br>52952<br>64 A                                                                                                                                            | US Modularly structured integrated services digital network  [ISDN] communication system        |                                                                                                                                                 | 709/10       |  |  |  |  |  |
| 64 | US<br>52671<br>90 A                                                                                                                                            | ×                                                                                               | Simultaneous search-write content addressable memory                                                                                            | 365/49       |  |  |  |  |  |
| 65 | US<br>52220<br>64 A                                                                                                                                            | ⊠                                                                                               | Bridge apparatus                                                                                                                                | 370/40       |  |  |  |  |  |
| 66 | US<br>52030<br>06 A                                                                                                                                            | ×                                                                                               | System for selecting next instruction address between unit incremented address and address from table specified by operating condition signals  | 711/21       |  |  |  |  |  |



DECODE UNIT DECODE UNIT 2

DECODE UNIT 2

DECODE UNIT 2

FIG. 11

|    | Docum<br>ent<br>ID  | σ                                                                                       | Title                                                                                                                                         | Current<br>OR |
|----|---------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 67 | US<br>51366<br>96 A | ⊠                                                                                       | High-performance pipelined central processor for predicting the occurrence of executing single-cycle instructions and multicycle instructions | 712/240       |
| 68 | US<br>50723<br>64 A | 0723 🛛 prediction in a processor that executes a family of 4 A instructions in parallel |                                                                                                                                               | 712/215       |
| 69 | US<br>47605<br>19 A | : - iderection and prediction                                                           |                                                                                                                                               | 712/217       |
| 70 | US<br>47501<br>12 A | ×                                                                                       | Data processing apparatus and method employing instruction pipelining                                                                         | 712/217       |
| 71 | US<br>45478<br>46 A |                                                                                         | Accessory interface circuit for universal multi-station document inserter                                                                     | 700/9         |
| 72 | US<br>44505<br>25 A | Ø                                                                                       | Control unit for a functional processor                                                                                                       | 712/243       |
| 73 | US<br>43631<br>03 A | $\sim$                                                                                  | Device for following and estimating the local state of picture contours                                                                       | 382/242       |



| TAG 4-<br>BIT | DEC | TAG 3-<br>BIT | TAG 3-<br>BIT | DEC | DEC2 | LV |
|---------------|-----|---------------|---------------|-----|------|----|
|               |     |               |               |     |      |    |

| TAG 4-<br>BIT DEC TAG 3- TAG 3-<br>BIT DEC DEC2 SU | TAG 4-<br>BIT | DEC | TAG 3-<br>BIT | TAG 3-<br>BIT | DEC | DEC2 | SU |
|----------------------------------------------------|---------------|-----|---------------|---------------|-----|------|----|
|----------------------------------------------------|---------------|-----|---------------|---------------|-----|------|----|

FIG. 12

## **ICNXTBLK**

